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Amendments to the Specification: 

Please replace paragraph [0002] with the following amended paragraph: 

[0002]This invention relates to generation, from graphically produced description of 
workflow process, of source code and bui l d i ng compiling and linking instructions of 
fully executable transactional workflow application with adaptive high-performance 
capacity for transactional workload processing of concurrent workflow and its real- 
time visualization. 

Please replace paragraph [0006] with the following amended paragraph: 

[0006]Customer-facing e-business applications are expected to sat is fy — two 
requ i rem e nts. First one is to respond in real-time to customer requests, requ e st. 
Second on e i s to have a capacity to initiate and conduct simultaneous processing of 
unpredictably high number of user interactions, and be process-centric, i.e. capable 
of executing set of related actions structured as transactional workflow. 
asynchronously arr i v i ng requ es ts. Buff e ring asynchronously arr i v i ng requests i n 
qu e ues and sub s equ e nt synchronous proc e ss i ng solv e s th e prob le m w i th reque s ts 
s pik es . Buff e r e d r e qu es ts, howev e r, wi ll not b e r es ponded i n rea l t i m e . H i gh 
r e spons i venes s of customer - fac i ng e bus i ness sy s tems, e.g. short t i m e i nterva l 
b e tw ee n s e nding a r e qu e st and r e c ei v i ng a r e spon s e w i th resu l t of request execution, 
i s already obl i gatory requ i r e m e nt. I n parall el with i ncrease i n futur e vo l um es of e- 
bus i nes s tran s act i ons, d i fficult i es assoc i ated w i th prov i d i ng h i gh respon s iveness of 
e busine ss s ystem s i s expect e d to s harpen. Eventual execution as single transaction, 
instead as transactional workflow, of all actions related to responding to a step of 
single user interaction will hold database locks until the transaction is completed or 
aborted. As a result, even when multiple instances of the same e-business 
application run concurrently, these instances will perform sequentially - one will hold 
database locks and all other will wait for database locks to be released. Therefore, 
the only way to cope with both increased number of concurrent users and increased 
processing complexity of user interactions while preserving real-time responsiveness 
is to use workflow systems with capacity for processing of high-volume concurrent 
transactional workflow. 
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Please replace paragraph [0007] with the following amended paragraph: 

[0007]Ability to adapt to changes in environment, competition, and customer needs 
means ab il ity of corporation to transform i ts e lf rap i d l y. Such tran s format i on implies 
high-speed of development of e-business systems deve l opment process and 
flexibility of existing e-business systems for future fine-grain changes within limited 
time. The most gener i c and flexible solutions, created with known technologies, 
satisfying those two requirements, are in form of workflow engine , workflow script 
and workflow activities' software components be i ng ab le to concurrent l y run mu l tip le 
workf l ow app li cat i ons . A workflow script appl i cation that w i l l run on an eng i n e is a 
form of description of workflow graph representing sequence of execution of 
workflow activities and software component representing tho s e act i vit i es . During 
workflow application running, workflow engine interprets workflow graph description 
and this results in execution of software components, representing workflow 
activities, in described sequence. If modifications of a workflow process are needed, 
desired results are achievable with changes in workflow graph, or components, or 
both. United States Patent Documents 20020040339, 20020065701, 20020170035, 
and 20020184616 demonstrate prior art related to concept of workflow engines. 

Please replace paragraph [0008] with the following amended paragraph: 

[0008]Such flexibility, however, has its price. The price is low efficiency of consumed 
resources, low processing speed, and lack of concurrency. Even if a hypothetical 
generic solution, in form of an workflow engine , script and components be i ng ab le to 
ftm — one — of — mor e — concurr e nt — workflow — processes — with — different — workflow 
configurat i ons , has the ability for concurrent processing of multiple requests, no 
such solution can compete in respect to s i mp li c i ty efficiency and speed with a 
proprietary executable application, designed and built for a particular workflow 
process. One of consequences that shou l d b e e xp e ct e d w i th an i ncrease i n simp li c i ty 
of workflow app li cat i on i s an i ncr e as e i n i ts e ffic i ency and s p ee d. Another factor that 
wW What may contribute to increasing workflow application efficiency and speed wHi 
be is any partial or full replacement of interpreted code with executable cod e 
l oadab l e — m — comput e r — m e mory — cede — s e gm e nts — fef — i nvok i ng — and — execut i on . 
Replacement of interpreted code with executable is the approach used with some 
Java Virtual Machine (IVM) based application servers. The performance improvement, 
however, does not extend over workflow concurrency because of the inherent 
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concurrency limitations of 1VM, With IVM application servers, the only way to process 
2 workflow requests concurrently is to concurrently run 2 workflow application 
instances. 

Please replace paragraph [001 7] with the following amended paragraph: 

[001 7] Preferred embodiment of invention's methods and art i c l e of manufacture for 
related to graphical development of transactional workflow application source code 
and building instructions is in form of an EXE file and two DLLs. This is invention's 
first embodiment. One of its DLLs contains components for interactive graphical 
design of workflow processes and for production of a descr i pt i on producing 
definition of designed workflow process from graphical objects representing the 
designed workflow process. The other DLL contains components producing custom 
source code and compiling and linking instructions, sufficient for building 
transactional workflow applications in form of fully executable code, from a 
description of a workflow process. 

Please replace paragraph [0018] with the following amended paragraph: 

[001 8] Preferred embodiment of invention's methods and art i c l e of manufactur e for 
system with adaptive high-performance capacity for processing of concurrent 
transactional workload proc e ss i ng is in form of three DLLs. This is invention's second 
embodiment. Two of its DLLs contain components with functionality enacting the 
high-performance capacity m for concurrent transactional workload processing of 
applications created with invention's first embodiment. Third DLL contains 
components for real-time visualization of workload processing. 

Please replace paragraph [001 9] with the following amended paragraph: 

[0019]This invention overcomes the limitations of known prior art methods for 
development of custom made application source code for fully executable workflow 
applications by providing a formal method of development of software source code 
for fully executable workflow applications. Thi s forma l method is used to bu i ld the 
art i cl e of manufactur e for g e n e ration of s ource cod e and compi li ng and link i ng 
i nstruct i on s , suffic i ent for bu il ding transact i onal workf l ow app li cation s i n form of 
fu l ly e x e cutabl e cod e . In the preferred embodiment, the generated source code is in 
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attributed Visual C++ and the generated compiling and linking instructions are in 
form of Microsoft Visual Studio .Net solution (.sin) and project (.proj) files. 

Please replace paragraph [0020] with the following amended paragraph: 

[0020] Transactional workflow applications i n form of executab le cod e, created 
with invention's first embodiment and using at run-time invention's second 
embodiment, are different from transactional workflow applications created with 
prior art s ystems, that are any form of scr i pt s run on workflow e ngin e s in regard to 
ability for high-volume concurrent processing . The d i fference i s i n appl i cat i ons' 
abi li ty to prov i d e performanc e capac i ty i n transact i onal work l oad processing h i gh e r 
then p e rformance capac i ty of appl i cations in form of scripts run on workflow 
eng i nes. Transactional workflow applications created with prior art have inherent 
concurrency limitations. As Web-accessible business applications must have capacity 
to serve unpredictably high number of concurrent users, concurrency limitation is a 
barrier in creation of Web applications processing user interactions with execution of 
transactional workflow such as. for example. Web-accessible facility for online 
negotiation of electronic purchases. This invention addresses the need for high- 
volume concurrent workflow by enabling concurrent processing of 1 .000 workflow 
instances per computer CPU. 

Please replace paragraph [0021] with the following amended paragraph: 

[0021] This invention's method ami — artic l e of manufacture for graphical 
development of source code for fully executable workflow applications is different 
from prior art non-standardized methods for development of software for executable 
workflow applications. The difference is best demonstrated by m the speed of 
software development process. The speed of software development with the 
invention's first embodiment is as fast as the speed of development of workflow 
applications in form of workflow scripts. No workflow application in form of script, 
however, can possess a capacity for more then just a very limited concurrency. 

Please replace paragraph [0022] with the following amended paragraph: 

[0022] This invention's method and art i cl e of manufacture for con s truct i ng a 
configuration system for transactional processing of workflow with a hierarchy of 
class objects and threads w i th capacity for high performance concurrent proce s s i ng 
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of mu l t i tude of transact i ona l workflow r e que s ts of ident i ca l type is different from 
known prior art system for transactional processing of workflow art i cle s of 
manufacture with capac i ty for h i gh - p e rformance concurrent processing of mult i tud e 
of transact i onal workflow requ es ts of i d e ntical typ e. The main difference is in 
flexibility of configurat i on hierarchy of class objects and threads to represent a non- 
limited number of workflow graphs and thereby to enact a non-limited number of 
workflow processes- Th e s e cond diff e renc e , r e su l t i ng from this flexib ili ty, i s th e 
s peed of development of transact i ona l workflow appl i cat i ons with capac i ty for high 
performance. The development t i me i s on l y a sma l l fract i on of development t i m e 
needed w i th pr i or art art i c les of manufactur e . 

Please replace paragraph [0024] with the following amended paragraph: 

[0024]This invention overcomes limitations of known prior art systems for 
transactional processing of workflow in their ability to counteract development of 
software related bottlenecks i n workflow appl i cat i ons du e to as result of variations of 
working conditions of in distributed application environment. Neutralization of 
development of software related bottlenecks is enacted by apparatus prov i ding a 
m e thod and art i c l e of manufacture ensuring that: workflow system appl i cat i on is 
supplied with sufficient number of threads for h i gh - p e rformance i n processing of 
transactional workload when an insufficiency is generated by var i ab le work i ng 
cond i t i ons of communication delays in distributed application environment; and no 
thread is overloaded with dispatching or supervising work. 

Please replace paragraph [0025] with the following amended paragraph: 

[0025]This invention overcomes limitations of known prior art systems, in their 
ability to visualize workflow application's thread structures, threads quantity, and 
threads usage , by providing a method and art i cl e of manufacture for real t i me 
v i sualizat i on of app li cat i on's thread structur es , threads quant i ty, thread s usage, and 
sca l ing enacted changes i n threads structure and quantity . Facilitation of real-time 
visualization will empower workflow application administrators with abilities to 
evaluate application workload, to detect points of delay caused by distributed 
infrastructure, and to observe application's scaling-related actions. 
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Please replace paragraph [0058] with the following amended paragraph: 

[0058] This invention is about engineering approach to s oftware dev el opm e nt and 
speed: speed of development and future modifications of workflow applications T 
speed of future appl i cat i on modificat i on, and most i mportant l y — re s u l ting product s ' 
ab il ity to and about enabling execution of perform large number of concurrent 
business interactions of s i milar type with h i gh speed. 

Please replace paragraph [0059] with the following amended paragraph: 

[0059] Invention provides method and article of manufactur e for graphical 
development of fully executable workflow applications. Application's graphical 
development has two phases: application design phase, where definition of a 
workflow process is interactively produced, and build phase, producing executable 
code of a workflow application that will perform in a way described by the definition 
of workflow process. 

Please replace paragraph [0079] with the following amended paragraph: 

[0079] Fig. 8 is block diagram of graphical development of a workflow application 
accord i ng to artic l e of manufacturing being described . Using a tool for graphical 
development of workflow applications based on th i s art i cle of manufactur e, a 
workflow application architect interactively executes workflow designer 801 and 
produces a definition of a workflow process 802. Execution of software generators 
803 takes as input a data set being a definition of a workflow process 802. Result of 
execution of software generators 803 includes: source code 804 of workflow 
application that after being compiled, linked, installed, and executed will behave 
according to the definition of a workflow process 802; compiling instruction 805 
necessary for compiling the generated source code 804; linking instructions 806 for 
producing application's executable code from results of execution of compiling 
instructions 805. Software source code generation is result of both analysis of 
description of desired workflow and knowledge of the art i cle of manufactur i ng be i ng 
embodiment of the rest of this invention. Generated software source code is 
responsible for customizable part of workflow application, dealing with application 
initialization and termination. The customizable part of application initialization 
facilitates construction of hierarchical trees of objects and hierarchical structure of 
threads. Source code generation involves usage of source code templates, class 
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templates, and pure generation of source code by created for this purpose program 
executable code, where elements of workflow definition are passed as input 
parameters of execution of this executable-code-provided functionality. Once 
results of execution of software generators 803 are obtained, compilers 807 are 
executed according to compiling instruction 805 taking as compilers' input 
generated source code 804 and results of compiling 808 are provided as input to 
linker execution 809 according to linking instructions 806 to produce workflow 
application executable code 810. 

Please replace paragraph [0081] with the following amended paragraph: 

[0081] Invention further includes a system provid e s a method and art i cle of 
manufacture produc i ng configuration of c l ass objects and thr e ads with capacity for 
concurrent processing of multitude of transactional workflow requests of identical 
type. Core of this system method and art i cle of manufacture is construction of 
hierarchy tfee of class objects with capacity to represent variety of workflow 
configurations and associated structure of threads with capacity for concurrent 
processing of multitude of workflow requests. In preferred embodiment, the 
workflow control-connectors and the not-mentioned-yet workflow notification- 
connectors are implemented as transactional MSMQ messages. 

Please replace paragraph [0098] with the following amended paragraph: 

[0098] Invention's method and art i cle of manufacture with capacity for concurrent 
processing of mu l t i tud e of transact i ona l workflow request s of i d e nt i ca l typ e r el at e s to 
a is enabled by hierarchical structure of threads with four levels and thread l evels 
re l at i ons and i nt e ract i on . The hierarchical structure levels below top level are 
organized as multitude of horizontally arranged divisions. Each division is 
autonomous and self-contained in conducting its tasks. Top level thread is 
responsible for making adaptive decisions, and executing and supervising adaptive 
behavior related to allocation and de-allocation of system resources based on its own 
assessment of application needs and goals. The provided by threads of the 
hierarchical structure capacity for concurrent processing of multitude of requests is 
limited only by environmental factors such as availability of reserve of system 
memory and unused CPU power and ability of networking infrastructure to cope with 
generated traffic. 
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Please replace paragraph [00107] with the following amended paragraph: 

[01 07] Invention further includes a method and — art i c le — of manufacture for 
transactional plugging of software components into workflow-process. The preferred 
embodiment of this method artic l e of manufacture uses services of COM+. It involves 
a Non-Transactional component and a Transactional component installed on a 
physical computer as a COM+ application and software components that will be 
trans i tiona l ly plugged into workflow process, installed on the same physical 
computer as a COM+ application. COM+ provides component-intercepting objects 
and functionality of just-in-time-activation for the Transactional component and for 
software components that will be trans i tiona ll y plugged into workflow process. The 
just-in-time-activation functionality ensures that when a method of a component- 
intercepting object is called, it will instantiate transactional object, call its method, 
vote for transaction on method exit, and destruct the transactional object. The Non- 
transactional component is a special kind of data holding component. The data it 
holds is required for execution of all future request-processing and request- 
forwarding transactions that will be performed by the processing thread. This data 
however is not specific or distinctive to any particular request. The main reason for 
existence of the non-transactional component is to prevent the processing thread 
from multiple transmissions of the mentioned, non-specific to any particular request, 
data over COM+ application process boundaries and multiple creations of the 
intercepting objects. 

Please replace paragraph [001 1 1] with the following amended paragraph: 

[01 1 l]The capacity for concurrent processing of multitude of tran s act i ona l workflow 
requests of identical type is achieved by the hierarchical structure of threads with 
four levels and by se t of methods and art i c l e of manufacture sp e c i fying interactions 
and division of labor between threads of hierarchical structure levels. The first in that 
s e t is th e m e thod and art i cl e of manufactur e for workload ba l anc i ng structured at 
two l evel s . Upper level of workload balancing comprises multitude of associations 
between a dispatching thread and multitude of supervising threads and involves 
dispatching thread, balancing workload between its associated supervising threads. 
Lower level of said workload balancing comprises multiple groupings of processing 
threads in pools associated with a supervising thread per pool and involves 
supervising threads balancing workload between processing threads of their 
associated pools. The rationale behind workload balancing with two levels is the need 
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to distribute the work, related to assignment of workload to processing threads and 
supervision of workload execution, between more threads and thereby to prevent 
threads responsible for this work from becoming workflow bottlenecks- 
Please replace paragraph [001 14] with the following amended paragraph: 

[0114]This invention provides a method apparatus for software bottlenecks' 
prevention- Software bottlenecks 1 prevention involves encapsulation of a thread pool 
containing fixed number of processing threads with a supervising thread in a 
processing-pipe. Number of processing threads per processing-pipe is 
experimentally selected in a way ensuring that, without modifying threads' priorities, 
even if processing threads conduct full-scale dummy workflow work, processing- 
pipe's supervising thread will still have enough capacity to cope with its duties. 
Having number of processing thread fixed guarantees that supervising thread will 
never be overloaded with work leading to existence of workload dispatched to it and 
waiting to be processed and at the same time existence of number of IDLE 
processing threads in its pool. 

Please replace paragraph [01 16] with the following amended paragraph: 

[0116] Software bottlenecks' neutralizing comprises construction of additional 
processing-pipes and inclusion of constructed additional processing-pipes in 
workload balancing process related to workflow-activity where development of 
bottleneck has been detected. Regulation of available workflow processing capacity 
includes a m e thod and apparatus for automatic detection of conditions requiring 
workflow application scaling up and for automatic execution of workflow application 
scaling up. The automatic detection in regard to a particular workflow-activity 
involves checking for conjunction of events, from all processing-pipes associated to 
said workflow-activity, signaling that number of idle threads in processing-pipe's 
pool reached its critical minimum. Application scaling up is automatically triggered at 
a particular workflow-activity to counteract development of a bottleneck at that 
particular workflow-activity and automatically triggered at all application's workflow- 
activities for higher application responsiveness when workload increases. Application 
scaling up might require creation of an additional processing-pipe. In this case it 
cannot be automatically triggered. If there is an available non-activated processing 
pipe, automatically triggered scaling up involves activation of an additional 
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processing-pipe and inclusion of said additional processing-pipe in workload 
balancing scheme. 

Please replace paragraph [0122] with the following amended paragraph: 

[01 22] Regulation of available workflow processing capacity further includes method 
«m4 apparatus for automatic detection of conditions requiring workflow application 
scaling down and for automatic execution of workflow application scaling down. 
Automatic detection in regard to a particular workflow-activity involves checking for 
conjunction of events, from all processing-pipes associated to said workflow-activity, 
signaling that number of busy threads in processing-pipe f s pool reached its critical 
minimum. Application scaling down is automatically triggered to counteract a 
detected inefficiency in use of system memory and CPU time slice allocated to 
application threads. 

Please replace paragraph [0126] with the following amended paragraph: 

[01 26] Final element of this invention is its system method and art i c le of manufactur e 
for real-time visualization of quantity, structure, and utilization of hierarchical 
structure of threads as they participate in processing of workflow requests. Threads 
forming the upper two levels of application's hierarchical structure of threads are not 
interesting for visualization since their quantity, type and status does not change 
after application is activated and before application is terminated. There is always 
one application supervising thread and total number of dispatching and 
synchronizing-dispatching threads is equal to number of workflow-activities. 
Additionally, where application's main flow of control shows more then one control- 
connectors having common destination node, the workflow-activity represented by 
this node will have synchronizing-dispatching thread, otherwise it will have 
dispatching thread. Threads forming First and Second levels of hierarchical structure 
of threads is where run-time changes happen and therefore hierarchical structure's 
adaptation-behavior-enacted modifications of First and Second levels are important 
for visualization. Visualization might be used as indicator of workload, indicator of 
points of delay caused by distributed infrastructure, and for observation and analysis 
of adaptive behavior of hierarchical structure of threads. 



